<template>
  <span class="adv-search-bar">
    <el-link type="primary" @click="open">{{$t('commons.adv_search.title')}}</el-link>
    <el-dialog :title="$t('commons.adv_search.combine')" :visible.sync="visible" custom-class="adv-dialog"
               :append-to-body="true">
      <div>
        <div class="search-items">
          <component class="search-item" v-for="(component, index) in config.components" :key="index"
                     :is="component.name" :component="component"/>
        </div>
      </div>
      <template v-slot:footer>
        <div class="dialog-footer">
          <el-button @click="reset">{{$t('commons.adv_search.reset')}}</el-button>
          <el-button type="primary" @click="search">{{$t('commons.adv_search.search')}}</el-button>
        </div>
      </template>
    </el-dialog>
  </span>
</template>

<script>
  import components from "./search-components";
  import {cloneDeep} from "lodash";

  export default {
    components: {...components},
    name: "MsTableAdvSearchBar",
    props: {
      condition: Object,
    },
    data() {
      return {
        visible: false,
        config: this.init()
      }
    },
    methods: {
      init() {
        let config = cloneDeep(this.condition);
        config.components.forEach(component => {
          let operator = component.operator.value;
          component.operator.value = operator === undefined ? component.operator.options[0].value : operator;
        })
        return config;
      },
      search() {
        let condition = {}
        this.config.components.forEach(component => {
          let operator = component.operator.value;
          let value = component.value;
          if (Array.isArray(value)) {
            if (value.length > 0) {
              condition[component.key] = {
                operator: operator,
                value: value
              }
            }
          } else {
            if (value !== undefined && value !== null && value !== "") {
              condition[component.key] = {
                operator: operator,
                value: value
              }
            }
          }
        });

        // 清除name
        if (this.condition.name) this.condition.name = undefined;
        // 添加组合条件
        this.condition.combine = condition;
        this.$emit('update:condition', this.condition);
        this.$emit('search', condition);
        this.visible = false;
      },
      reset() {
        let source = this.condition.components;
        this.config.components.forEach((component, index) => {
          if (component.operator.value !== undefined) {
            let operator = source[index].operator.value;
            component.operator.value = operator === undefined ? component.operator.options[0].value : operator;
          }
          if (component.value !== undefined) {
            component.value = source[index].value;
          }
        })
        this.condition.combine = undefined;
        this.$emit('update:condition', this.condition);
        this.$emit('search');
      },
      open() {
        this.visible = true;
      }
    }
  }
</script>

<style>
  @media only screen and (min-width: 1870px) {
    .el-dialog.adv-dialog {
      width: 70%;
    }
  }

  @media only screen and (min-width: 1650px) and (max-width: 1869px) {
    .el-dialog.adv-dialog {
      width: 80%;
    }
  }

  @media only screen and (min-width: 1470px) and (max-width: 1649px) {
    .el-dialog.adv-dialog {
      width: 90%;
    }
  }

  @media only screen and (max-width: 1469px) {
    .el-dialog.adv-dialog {
      width: 70%;
      min-width: 695px;
    }
  }
</style>

<style scoped>
  .adv-search-bar {
    margin-left: 5px;
  }

  .dialog-footer {
    text-align: center;
  }

  .search-items {
    width: 100%;
  }

  @media only screen and (max-width: 1469px) {
    .search-item {
      width: 100%;
    }
  }

  @media only screen and (min-width: 1470px) {
    .search-item {
      width: 50%;
    }
  }

  .search-item {
    display: inline-block;
    margin-top: 10px;
  }
</style>
